-
Notifications
You must be signed in to change notification settings - Fork 4.5k
feat(tree-shaking): enable browser target webpack tree-shaking #21055
feat(tree-shaking): enable browser target webpack tree-shaking #21055
Conversation
Tried it in wallet-adapter-react-ui-starter, seems to work and bring fair enough gains. UncompressedBefore
After
Change
gzipped< 372.94 KB build/static/js/2.13d77f2a.chunk.js
< 19.46 KB build/static/js/main.9ead91a1.chunk.js
---
> 343.15 KB build/static/js/2.1217a4d1.chunk.js
> 34.4 KB build/static/js/main.b53f84c0.chunk.js |
bump |
I'm using this version in a web project with Webpack, FWIW, this is the required configuration:
The
|
Thank you, I'll have another look today! |
With the latest commit, the required webpack / consumer configuration is now:
The thing is, the following piece of code needs to be eliminated for browser builds: src/connection.ts
So far I'm succesful in elimintating the |
feat(tree-shaking): make an unbundled transpiled build using Babel These files are meant to be consumed by Webpack in a way that will enable tree-shaking. feat(tree-shaking): enable webpack tree-shaking by marking lib as side-effects free Even though this is not exactly true, web3.js isn't strictly pure, it should be safe.
This way we don't have to force the consumer to do it themselves, also closer to the previous ESM bundled behavior.
8efdfa4
to
b124896
Compare
removes the need of resolving http/https modules by consumers
With the latest commit, I'm able to remove the dead import from the transpiled ESM output files, but I'm not too happy about it. I also confirmed the tree-shaking still works as intended with a webpack consumer, and no longer requires any specific bundler configuration. Thoughts? |
I'm testing out the latest commits, but wanted to bring in @jstarry since he's more familiar with this area. |
transformEnvVariables && [ | ||
'babel-plugin-transform-remove-imports', | ||
{ | ||
test: 'agent-manager', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not really satisfied by this solution, forces the build to be aware that a specific import is unused in specific conditions ̛& needs to be removed.
I believe it might be best to not remove the import, and in fact ship the code containing references to http[s]
Node.js module, even if it forces additional yet trivial configuration of consumers (which in most cases, is covered by frameworks build)
}, | ||
], | ||
transformEnvVariables && [ | ||
'minify-dead-code-elimination', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If we consider https://github.com/solana-labs/solana/pull/21055/files#r759707513, then this becomes unnecessary as well, the consumer's bundler / minifier will remove the bit of dead code:
if (!process.env.BROWSER) {
agentManager = new AgentManager(useHttps);
}
}, | ||
], | ||
transformEnvVariables && [ | ||
'transform-inline-environment-variables', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This on the other hand, I think is good to keep in any case, since it enables not forcing consumers to inject themselves inlined process.env.BROWSER
& process.env.NODE_ENV
values in their builds (even though, process.env.NODE_ENV
is injected by most bundlers automatically today)
@0xCryptoSheik Is this also removing the node builtins so it will work on Webpack 5 and Vite? Thank you for doing this! |
This pull request has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. |
This stale pull request has been automatically closed. Thank you for your contributions. |
Hey, I'm throwing a few ideas at the tree-shaking issue of web3.js, would love some feedback, or some help testing / challenging this :)
Summary of Changes
These files are meant to be consumed by Webpack in a way that will
enable tree-shaking.
Even though this is not exactly true, web3.js isn't strictly pure, it
should be safe.
See https://webpack.js.org/guides/tree-shaking/
Twitter thread: https://twitter.com/0xCryptoSheik/status/1453342552007057415
Only tested the most simplistic scenario with https://github.com/0xCryptoSheik/treeshake-solana-web3js
Fixes solana-labs/solana-web3.js#1122
/!\ Do not merge, needs thorough testing I can't do on my own.